<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd">
<html lang="ja">
<head>
  <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
  <meta http-equiv="Content-Style-Type" content="text/css">
  <title>静的ページプラグイン | Geeklogドキュメント</title>
  <link rel="stylesheet" type="text/css" href="../docstyle.css" title="Dev Stylesheet">
  <link rel="stylesheet" type="text/css" href="docstyle.css" title="Dev Stylesheet">
</head>

<body>
<p><a href="http://www.geeklog.jp" style="background:transparent"><img src="../images/newlogo.gif" alt="Geeklog Documentation" width="243" height="90"></a></p>
<div class="menu"><a href="index.html">Geeklogドキュメント</a> - 静的ページプラグイン</div>

<h1>静的ページプラグイン</h1>

<h2><a name="about">概要</a></h2>

<p>静的ページプラグインは、本来、（Geeklogが作成する動的ページとは対照的に）静的コンテンツを持ったページを作成するためのものでした。そういうわけで「静的」という名前になっています。「このサイトについて」や「目標宣言」などのページが思い浮かぶでしょう。</p>

<p>その時以来、人々は様々な目的で静的ページを使用しています。静的ページにPHPのコードを含めることができるようになっていますので、静的ページという名前はもはやだいぶ不適切なものになっています。</p>


<h2><a name="features">機能</a></h2>

<ul>
  <li><a href="#php">PHPの使用</a>をサポート</li>
  <li>読みやすいURLを作成するための<a href="#id">編集可能なページID</a></li>
  <li>静的ページをGeeklogの<a href="#frontpage">インデックスページと話題ページ</a>に表示し、全画面表示することもできる("スプラッシュスクリーン機能")</li>
  <li>既存のページを<a href="#cloning">コピーする</a>機能</li>
  <li>Geeklogの<a href="#url">URL書き換え</a></li>
  <li><code>[staticpage:]</code> と <code>[staticpage_content:]</code> 自動タグを実装</li>
  <li>Geeklogのパーミッションシステムを適切にサポート</li>
</ul>


<h2><a name="php">PHPの使用</a></h2>

<h3><a name="activation">PHPを使えるようにする</a></h3>

<p><strong>重要:</strong> セキュリティ上の理由で、静的ページでのPHP使用はデフォルトでは無効になっています。有効にするには、Static Page Adminグループに、 <code>staticpages.PHP</code> 権限を与える必要があります。そのためには、管理者としてログインし、管理者用メニューから「グループ」を選択します。Static Page Adminを見つけて、グループ名の左側にある編集アイコン（ペンの形）をクリックします。ページの下の方に「権限(Rights)」のリストがあり、<code>staticpages.delete</code> と <code>staticpages.edit</code> には既にチェックが入っています。Static Page Adminグループに属する人が静的ページでPHPを使えるようにするには、 <code>staticpages.PHP</code> にチェックを入れてから保存をクリックします。</p>

<p>上述の <code>staticpages.PHP</code> 権限に加えて、静的ページ全体でPHPの使用を無効にするグローバルなオプションもあります。このオプションは「管理者用メニュー - コンフィギュレーション - 静的ページ」の中にある「PHPを許可する」です。「いいえ」にすると、<code>staticpages.PHP</code> よりも優先され、静的ページの中でPHPを使えなくなります。</p>

<h3><a name="usage">使用法</a></h3>

<p style="text-align:center"><em>静的ページでPHPを不適切に使用すると、セキュリティの問題が発生する可能性があります。注意して使用してください。</em></p>

<p>静的ページごとにPHPの使用を有効にする必要があります。コンテンツ編集欄の下に、次の選択肢のあるPHPのドロップダウンリストがあります。</p>
<ul>
<li>PHPを実行しない<br>
静的ページの中にPHPのコードが含まれていても、<em>実行されず</em>、コードがそのまま表示されます。</li>
<li>PHPを実行する(return)<br>
静的ページに含まれるPHPのコードが<em>実行されます</em>。'return'とは、このページが表示する内容をPHPのコードで（<code>echo</code> 文や <code>print</code> 文を使って）直接出力する代わりに <code>return</code> 文で返すことを意味します。これは静的ページプラグイン ver 1.3から導入されたオプションです。</li>
<li>PHPを実行する<br>
静的ページに含まれるPHPのコードが<em>実行されます</em>。このオプションを使うと、ページレイアウトに干渉することなくPHPの <code>echo</code> 文や <code>print</code> 文を使ってページの内容を出力できます。</li>
</ul>

<p>静的ページにPHPのコードを埋め込むときに、PHPの <code>&lt;?php</code> タグと <code>?&gt;</code> タグを<em>記述してはいけません</em>。静的ページに含まれるPHPのコードは、Geeklog側でこれらのタグを付加されて実行されるからです。</p>

<p>上述の「PHPを実行する」（returnなしの方）を選択する場合は、コードの中でPHPとHTMLを次のように行き来することができます。</p>
<pre style="padding-left: 2em"><code>echo "Hello"; ?&gt;, &lt;b&gt;world&lt;/b&gt;, &lt;?php echo "how are you?";</code></pre>
<p>この例では、 "Hello, <b>world</b>, how are you?" と表示されます。</p>


<h2><a name="id">ページID</a></h2>

<p>静的ページを新規作成すると、ページIDが自動的に割り当てられます。このIDは日付・時刻と最大3桁のランダムな数字で構成されています。このページのURLを頻繁に使用するつもりなら（Eメールで引用する場合など）、もっと読みやすいページIDにするのは意味のあることでしょう。</p>

<p>「静的ページの編集」では、ページIDを変えることもできます。たとえば、「当サイトに関して」のページのIDを "20030313100131123" から "about" に変えて、次のURLにできます。</p>

<p style="margin-left:4em;"><tt>http://yoursite/staticpages/index.php?page=about</tt></p>

<p>こちらの方が遙かに引用しやすいし、覚えやすいです。Geeklogの<a href="#url">URLリライト機能</a>を活用してさらに改善することもできるでしょう。</p>

<p>ページIDで安全に使える文字はアルファベットと数字だけです。各国固有の文字（ひらがな、カタカナ、漢字など）やほとんどの句読点(とはいえ、'-' と '.' は使えるはず)、スペースは使用しないでください。「静的ページの編集」は一部の不正な文字を検出しますが、全部というわけではありません。</p>


<h2><a name="frontpage">静的ページをインデックスページで使用する</a></h2>

<p>Geeklogのセンターブロックの概念では、プラグインがサイトのセンターエリア（つまり、記事と記事の間）にブロックを出力することを許可しています。</p>

<p>「静的ページの編集」で「センターエリア」にチェックを入れると、静的ページを表示する場所を選択するために、「表示エリア」と「話題」というドロップダウンリストが使えるようになります。「表示エリア」で選べるのは、「ページの最上部」、「注目記事の下」、「ページの下」（この3つは説明不要でしょう）と「ページ全体」です。最後の「ページ全体」とは、この静的ページがインデックスページとして表示される、つまり、通常の記事が一切表示されなくなるということです。サイトの「スプラッシュ画面」や「ようこそ」ページを作成するのに役に立つでしょう。</p>

<p><strong>ヒント:</strong> 静的ページをスプラッシュ画面として使用する場合、訪問者を普通のインデックスページへ誘導するリンクが必要になることもあるでしょう。この場合は、静的ページの中に <code>index.php?display=all</code> というリンクを作成すればよいでしょう。</p>

<p>2番目の「話題」ドロップダウンリストを使うと、静的ページの表示を特定の話題、ホームページ（トップページ）のみ、全ページ（つまり、すべての話題 + ホームページ）に限定できます。これはブロックを表示するオプションと全く同じです。</p>

<p><strong>ヒント:</strong> これらのオプションをパーミッションと組み合わせることもできます。たとえば、ゲストユーザにしか表示されない「ようこそ」ページを作成することも可能です。</p>

<h3><a name="sort">ソート（並べ換え）</a></h3>

<p><strong>センターブロックでのソート項目:</strong> センターエリアの同一セクション内（たとえば、インデックスページのトップに静的ページを2つ表示する場合）に複数の静的ページを表示させる場合、「管理者用メニュー - コンフィギュレーション - 静的ページ」で表示順を選ぶことができます。選択肢は、次の通りです。</p>
<ul>
<li>日付（更新日時の新しい順に並べ換え）</li>
<li>ページID（ページIDで並べ換え：初期値）</li>
<li>タイトル（ページのタイトルで並べ換え）</li>
</ul>
<p>この順序が適用されるのは、センターブロック内の静的ページだけです。センターブロックを出力する他のプラグインはこの順序には含まれません。また、センターブロックは普通のGeeklogのブロックのような外見をしているとは限りません。この目的のためには、下にある「ページをブロックで囲む」を「はい」にします。</p>

<p><strong>メニューでのソート項目:</strong> サイトのメニューに表示される静的ページを並べ換えることもできます(<tt>header.thtml</tt> テンプレートファイル内で、 <code>{plg_menu_elements}</code> 変数を使用している場合)。この項目も「管理者用メニュー - コンフィギュレーション - 静的ページ」で表示順を選ぶことができます。選択肢は、次の通りです。</p>
<ul>
<li>日付（更新日時の新しい順に並べ換え）</li>
<li>ラベル（メニューに表示される文字列：初期値）</li>
<li>ページID（ページIDで並べ換え：初期値）</li>
<li>タイトル（ページのタイトルで並べ換え）</li>
</ul>


<h2><a name="block">静的ページをブロックで囲む</a></h2>

<p>「静的ページの編集」で「ブロックで囲む」をチェックすると、静的ページをGeeklogのブロックレイアウトで囲むことができます。この場合、静的ページのタイトルがブロックのタイトルとして使用されます。また、普通のブロックと同様にヘルプ表示用のURLを入力することもできます。URLを入力すると、そのURLにリンクするヘルプアイコンが表示されます。</p>

<p>このオプションの初期値は、「管理者用メニュー - コンフィギュレーション - 静的ページ」で設定することができます。</p>


<h2><a name="cloning">静的ページをコピーする</a></h2>

<p>同じような静的ページがたくさんある場合、既存のページをコピーしてから編集したいでしょう。静的ページのリストで、コピー欄のアイコンをクリックすれば簡単にコピーできます。コピーすると新たなページIDがついたページができます。</p>


<h2><a name="url">URLリライト</a></h2>

<p style="margin-left:4em;"><em>この機能は実験的なものであり、<acronym title="Internet Information Service">IIS</acronym>では動作しないことが知られています。</em></p>

<p>Geeklogはある種のURL書き換え、つまり、URLの外観を検索エンジンに拾われやすいものにする機能を持っています。たとえば、</p>

<p style="margin-left:4em;"><tt>http://yoursite/staticpages/index.php?page=20030313100131123</tt></p>

<p>の代わりに、次のような外観にすることができます。</p>

<p style="margin-left:4em;"><tt>http://yoursite/staticpages/index.php/20030313100131123</tt></p>

<p>検索エンジンの中には、URLに '?' や '=' などの文字が含まれていると、そのページをインデックスに登録しないものがあるということが知られています。これをさらに推し進めて、<a href="#id">数字で構成されたページID</a>を（できれば、ページの内容と関連する）単語や表現に置き換えることで、検索エンジンにさらに登録されやすくすることもできるでしょう。</p>

<p style="margin-left:4em;"><tt>http://yoursite/staticpages/index.php/about</tt></p>

<p>URL書き換えを行うには、「管理者用メニュー - コンフィギュレーション - Geeklog - サイト」で「URLリライト」を「はい」にする必要があります。</p>

<h3><a name="delete">所有者の削除と共に削除する</a></h3>

<p>Geeklogのすべてのオブジェクト同様、静的ページには所有者（そのページの作成者）がいます。そのユーザのアカウントが何らかの理由で削除された場合、そのユーザが所有していた静的ページも削除するか、GeeklogのRootグループに属する人に引き継がせることができます。</p>

<p>「管理者用メニュー - コンフィギュレーション - 静的ページ」で「所有者の削除と共に削除する」を「いいえ」（初期値）にすると、所有者が削除されても作成した静的ページは削除されず、Rootグループのメンバ（ユーザIDが最も若い人、つまり、たいていはサイトの管理者）に引き継がれます。「はい」にすると、所有者のアカウントが削除されたとき、作成した静的ページも削除されます。</p>

<h2><a name="config.php">コンフィギュレーション</a></h2>

<p>静的ページプラグインのコンフィギュレーションオプションは、コンフィギュレーション管理画面で変更:</p>

<h3><a name="main">静的ページの主な設定</a></h3>

<table>
<tr><th style="width:25%">項目</th>
    <th style="width:25%">初期値</th>
    <th style="width:50%">説明</th>
</tr>
<tr>
  <td><a name="desc_allow_php">PHPを許可する</a></td>
  <td><code>はい</code></td>
  <td>静的ページにおいて、<a href="#php">PHPを許可する</a>。つまり、この設定で、個々のページの設定を上書きします</td>
</tr>
<tr class="r2">
  <td><a name="desc_sort_by">センターブロックでのソート項目</a></td>
  <td><tt>ページID</tt></td>
  <td>センターブロックに静的ページが複数表示される場合の順番を設定します。ページID、ページタイトル、最後に編集した日付から選べます。</td>
</tr>
<tr>
  <td><a name="desc_sort_menu_by">メニューでのソート項目</a></td>
  <td><tt>ラベル</tt></td>
  <td>サイトメニューの順番を設定します。ページラベル、ページID, ページタイトル、最後に編集した日付から選べます。</td>
</tr>
<tr class="r2">
  <td><a name="desc_delete_pages">所有者の削除と共に削除する</a></td>
  <td><tt>いいえ</tt></td>
  <td>ページの所有者のアカウントが削除された場合、つまりその静的ページを最初に作成したユーザが居なくなった場合、そのページを'True'なら削除、'False'なら"Root"グループのユーザ(通常は最も小さい値のIDのRootユーザ)に変更します。</td>
</tr>
<tr>
  <td><a name="desc_in_block">ページをブロックで囲む </a></td>
  <td><tt>はい</tt></td>
  <td>静的ページを作成する際、ページをブロックで囲むモードのデフォルトを設定します。</td>
</tr>
<tr class="r2">
  <td><a name="desc_show_hits">ヒット数を表示する </a></td>
  <td><tt>いいえ</tt></td>
  <td>閲覧回数を表示するかどうかを設定します。</td>
<tr>
<tr>
  <td><a name="desc_show_date">日時を表示する</a></td>
  <td><tt>はい</tt></td>
  <td>最後に編集した日時を表示するかどうかを設定します。</td>
</tr>
<tr class="r2">
  <td><a name="desc_filter_html">HTMLフィルターを適用する</a></td>
  <td><tt>いいえ</tt></td>
  <td>GeeklogのHTMLフィルターを静的ページの編集時に適用させるかどうかを設定します。</td>
</tr>
<tr>
  <td><a name="desc_censor">内容を検閲する</a></td>
  <td><tt>いいえ</tt></td>
  <td>Geeklogの"バッドワード"フィルターを静的ページの編集時に適用させるかどうかを設定します。
  </td>
</tr>
<tr class="r2">
  <td><a name="desc_aftersave">ページ保存後の画面遷移</a></td>
  <td><tt>静的ページ管理を表示する</tt></td>
  <td>静的ページ保存後の画面遷移を設定します:
    <ul>
    <li>編集した静的ページを表示する</li>
    <li>静的ページ管理を表示する(default)</li>
    <li>ホームを表示する</li>
    <li>管理画面トップを表示する</li>
    </ul></td>
</tr>
<tr>
  <td><a name="desc_atom_max_items">フィードに書き出す最大ページ数</a></td>
  <td>10</td>
  <td>ウェブサービスAPIによってatomフィードに書き出す静的ページ数の最大値。</td>
</tr>
</table>

<div class="footer">
    <a href="http://wiki.geeklog.net">Geeklogドキュメント作成プロジェクト(The Geeklog Documentation Project)</a><br>
    本ページのすべての商標と著作権はそれぞれの所有者に帰属します。Geeklogはコピーレフトです。
</div>
</body>
</html>
